<template>
  <div class="pana-tab__content">
    <a-form
        size="small"
        laba-width="90px"
        laba-suffix="："
    >
      <a-form-item label="异步延续">
        <a-checkbox
            v-model="taskConfigForm.asyncBefore"
            @change="changeTaskAsync"
        >
          异步前
        </a-checkbox>
        <a-checkbox
            v-model="taskConfigForm.asyncAfter"
            @change="changeTaskAsync"
        >
          异步后
        </a-checkbox>
        <a-checkbox
            v-if="taskConfigForm.asyncAfter || taskConfigForm.asyncBefore"
            v-model="taskConfigForm.exclusive"
            @change="changeTaskAsync"
        >
          排除
        </a-checkbox>
      </a-form-item>
      <component
          :is="witchTaskComponent"
          v-bind="$props"
      />
    </a-form>
  </div>
</template>

<script>
import UserTask from './task-components/UserTask'
import ScriptTask from './task-components/ScriptTask'
import ReceiveTask from './task-components/ReceiveTask'

export default {
  name: 'Task',
  components: { UserTask, ScriptTask, ReceiveTask },
  props: {
    id: String,
    type: String
  },
  data() {
    return {
      taskConfigForm: {
        asyncAfter: false,
        asyncBefore: false,
        exclusive: false
      },
      witchTaskComponent: '',
      installedComponent: {
        // 手工任务与普通任务一致，不需要其他配置
        // 接收消息任务，需要在全局下插入新的消息实例，并在该节点下的 messageRef 属性绑定该实例
        // 发送任务、服务任务、业务规则任务共用一个相同配置
        UserTask: 'UserTask', // 用户任务配置
        ScriptTask: 'ScriptTask', // 脚本任务配置
        ReceiveTask: 'ReceiveTask' // 消息接收任务
      }
    }
  },
  watch: {
    id: {
      immediate: true,
      handler() {
        this.bpmnElement = window.bpmnInstances.bpmnElement
        this.taskConfigForm.asyncBefore =
          this.bpmnElement?.businessObject?.asyncBefore
        this.taskConfigForm.asyncAfter =
          this.bpmnElement?.businessObject?.asyncAfter
        this.taskConfigForm.exclusive =
          this.bpmnElement?.businessObject?.exclusive
      }
    },
    type: {
      immediate: true,
      handler() {
        this.witchTaskComponent = this.installedComponent[this.type]
      }
    }
  },
  methods: {
    changeTaskAsync() {
      if (!this.taskConfigForm.asyncBefore && !this.taskConfigForm.asyncAfter) {
        this.taskConfigForm.exclusive = false
      }
      window.bpmnInstances.modeling.updateProperties(
        window.bpmnInstances.bpmnElement,
        {
          ...this.taskConfigForm
        }
      )
    }
  }
}
</script>
